草庐IT

python - SQLalchemy,原始查询和参数

全部标签

ruby - Ruby 中从 URL 中删除参数的最优雅的方法是什么?

我想通过名称从URL中取出一个参数,但不知道它是哪个参数,然后重新组合URL。我想我自己使用CGI或URI编写一些东西并不难,但我想这样的功能已经存在了。有什么建议吗?在:http://example.com/path?param1=one¶m2=2¶m3=something3输出:http://example.com/path?param2=2¶m3=something3 最佳答案 我更喜欢使用:require'addressable/uri'uri=Addressable::URI.parse('http

ruby - 哪个查询去了哪个数据库的 ActiveRecord 日志

在与不同数据库有多个连接的ActiveRecord应用程序中,日志中没有任何内容表明哪个查询去了哪个数据库。这些查询分离数据库:Base1.connection.select_value("select*fromfoo")Base2.connection.select_value("select*fromfoo")发出这些日志条目:D,[2017-03-13T09:27:11.844395#22112]DEBUG--:(0.6ms)select*fromfooD,[2017-03-13T09:27:11.844539#22112]DEBUG--:(0.1ms)select*fromfo

ruby-on-rails - 如何清理 Rails 4 中的原始 SQL

在Rails3中,我可以使用sanitize_sql_array为那些偶尔需要原始SQL查询的时刻清理原始SQL。但这似乎已在Rails4中删除,或者没有删除太多,而是移至ActiveRecord::Sanitization。但是,我现在不知道如何调用sanitize_sql_array,那么在Rails4中清理原始SQL的最佳方法是什么?我想澄清一下,我在这里谈论的是完整的原始SQL查询,而不是使用Rail的模型。我知道这不是最佳实践,这正是我必须为这个特定查询做的事情,因为它不能用Rails漂亮的ActiveRecord接口(interface)表示(相信我,我已经试过了)。这是一

ruby-on-rails - Rails,如何避免 "N + 1"查询关联中的总数(计数、大小、counter_cache)?

我有这些模型:classChildren我现在需要的是在“电影院”的页面中,我想为那个电影院的电影打印children的总和(数量,大小?),所以我这样写:在cinemas_controller.rb中:@childrens=@cinema.childrens.uniq在cinemas/show.html.erb:但显然我有bulletgem提醒我Counter_cache并且我不知道把这个counter_cache放在哪里因为电影的不同id。而且在没有counter_cache的情况下,我所拥有的也不是我想要的,因为我想要计算该电影院中有多少child从该电影院许多天的门票中拿走了他

ruby - 是否可以在 RSpec 中使用参数化规范?

如果我有一个规范需要以不同的值运行以使其驱动真正的实现而不是天真的实现。一个例子:it"shouldreturn'fizz'formultiplesofthree"do@fizzbuzz.get_value(3).should=="fizz"end到目前为止,我还没有找到任何方法将3作为参数传入。下面的规范解决了我的问题,但我想知道这是否是推荐的方法,或者是否有任何其他更好的方法。it"shouldreturn'fizz'formultiplesofthree"do[3,6].each{|number|@fizzbuzz.get_value(number).should=="fizz"

ruby-on-rails - 在 Rails 控制台中创建实例时 Rails 4 强参数失败

可能在这里做了一些愚蠢的事情,但这是我的基本千篇一律类:classLeague在创建一个新的League实例时:2.0.0-p0:001>l=League.new(full_name:'foo',short_name:'bar')WARNING:Can'tmass-assignprotectedattributesforLeague:full_name,short_name我到底做错了什么?这是Rails4.0.0.beta1构建+Ruby2.0**更新**我现在意识到强参数现在是在Controller中强制执行的,而不是在模型中。原来的问题仍然成立。如果它们在Controller级别

ruby-on-rails - ruby 中 CSV.open( ) 的第二个参数/参数是什么?

我想我在这里遗漏了一些非常明显的东西,但是每个人为CSV.open方法输入的第二个参数是什么,在本例中是“wb”,我看到这里放了其他字母,但没有人真正解释它的作用。它有什么作用?CSV.open("path/to/file.csv","wb")do|csv|csvruby文档似乎没有给出任何解释。http://www.ruby-doc.org/stdlib-2.0/libdoc/csv/rdoc/CSV.html谢谢! 最佳答案 来自IOOpenMode文档:"r"只读,从文件开头开始(默认模式)。"r+"读写,从文件开头开始。"w

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d

ruby - Ruby 中的命名命令行参数

有没有办法将命名参数传递给Ruby脚本?我理解ARGV传递参数的方式,但是这要求它们必须有一定的顺序。我想做的是传递命名参数,类似于其他命令行操作。例如:$rubysomeRubyScript.rb-aargumentA-bargumentB有什么想法吗? 最佳答案 有几个选项。OptionParser,在标准库中,是最受欢迎的之一。它可以完全满足您的需求,而且API也很不错。GetOptLong也在标准库中,它重新实现了POSIX风格的命令行。如果您想模拟Unix命令行应用程序,这一切都可以做到。AraT.Howard的Main是

Ruby 使用/附加字符串参数重新引发异常

情况是这样的。我希望doStuff()中的所有异常通过代码冒泡,以便在更高级别处理它们。我还想记录在更高级别的doStuff()中发生任何异常的频率,目前正在这样做:begindoStuff()rescueException=>raisee,"specificerrortologinadb"doStuff代码抛出了几十个异常,我想捕获这些事件中的每一个以放入数据库中。有一个doStuff2(),它也可以抛出相同的指令,我想知道它们来自哪个函数。添加额外的字符串,似乎改变了异常本身,我失去了原始异常所具有的所有漂亮的格式和跟踪信息。关于如何重新引发原始异常,同时跟踪doStuff()中发